草庐IT

C++ 引用和 C 指针

全部标签

GO语言如何改变 map 指针内部对象的值

我该怎么做?我有对象列表,我想列出所有对象并更改对象名称。我有列表,我正在做一段时间发送到另一个函数,在那里我更改了名称,但名称没有保存。知道我该怎么做吗?https://play.golang.org/p/el3FtwC-3U如果有任何我可以阅读以了解更多信息的书籍,请。谢谢你帮助我=D 最佳答案 在范围循环中:for_,track:=rangetracks{//sendtracktochanneltochangethenameWorking(&track,&c)}track变量实际上是映射中包含的值的副本,因为这里的赋值作用于T

测试 HTTP 请求时出现 Nil 取消引用错误

我正在尝试在我的Go库中测试HTTP请求。进行调用的对象通过依赖注入(inject)接受HTTP客户端对象,因此在我的测试中,我像这样模拟HTTP客户端:funcTestMyObject(t*testing.T){server:=httptest.NewServer(http.HandlerFunc(func(whttp.ResponseWriter,r*http.Request){w.WriteHeader(200)w.Header().Set("Content-Type","application/json")fmt.Fprintln(w,mockJSONResponse)}))d

go - 引用库中的另一个.go文件

我是Go的新手,我已经经历了HowtoWriteGoCode虽然它非常有帮助,但我对如何使用同一个库中的go文件感到困惑。例如,这是我的结构:~/src/hashtable/hashtable.golinkedlist.go我想在哈希表中使用链表。我的目录结构应该是什么,我应该使用什么包名? 最佳答案 在Go中,两个或多个具有相同包名称的文件被视为一个包,这意味着在命名空间内可以访问所有内容,包括私有(private)(小写)和公共(public)(大写)符号。例如,如果hashtable.go和linkedlist.go共享相同的

function - 指向函数参数中接口(interface) slice 的指针

我有以下功能:funcread(filePathstring,structure*[]interface){raw,err:=ioutil.ReadFile(filePath)iferr!=nil{fmt.Println(err.Error())os.Exit(1)}json.Unmarshal(raw,structure)}我这样调用它:indexes:=[]Indexread(path+"/"+element+".json",&indexes)但是,当我从函数声明中删除structure*[]interface时,我遇到了奇怪的错误,该错误消失了:./index.verb.go:7

pointers - 指向结构的指针更改未反射(reflect)在调用者中

我将一个指向结构的指针传递给另一个名为someFunc()的函数并在那里进行更改,但在本例中,它不会反映在调用方函数中。typeSlotstruct{f1intf2stringf3[]*string}funcNewSlot(f1,f2){return&Slot{f1:f1,f2:f2,f2:make([]*string,0)}}funcmain(){slots:=&Slots{}scanner:=bufio.NewScanner(os.Stdin)forscanner.Scan(){s:=scanner.Text()sarr:=strings.Split(s,"")fmt.Printl

go - 具有指针类型接收器的方法不会在反射中列出

我试图通过使用反射来调用一个类型的所有方法来概括我的代码。它简单明了,但存在一个问题,reflection.TypeOf(T).NumMethods(或其他方法)忽略了使用接收器类型作为指针的方法。例如,这段小代码将打印1而不是2:packagemainimport("fmt""reflect")typeFoostruct{}func(fFoo)Bar(){}func(f*Foo)Baz(){}funcmain(){obj:=Foo{}fmt.Println(reflect.TypeOf(obj).NumMethod())}您可以在playground中运行.它打印1因为Bar方法。如

go - 为什么要在堆上存储指针语义的值?

WilliamKennedy(goinaction的作者)说,在go中,有两种语义。存储在堆栈上的值语义意味着我们在跨越这些程序边界时正在制作值的副本。存储在堆上的指针语义意味着我们在跨越程序边界时共享值。垃圾收集器有时会启动以回收堆上未使用的内存。我想知道为什么指针语义的值存储在堆上。你能解释一下吗? 最佳答案 任何时候在函数栈帧范围之外共享一个值,它都会被放置(或分配)在堆上。发现这些情况并在程序中保持一定程度的完整性是逃逸分析算法的工作。完整性在于确保对任何值的访问始终准确、一致且高效。引用:https://www.ardan

oop - 在 golang 中将类型定义为引用

令我惊讶的是这个街区typeObject*struct{Xint}在golang中编译。但是,我不知道如何创建底层结构的实例。在功能上,我想要实现的是在没有hack的情况下从所有类型签名中删除所有星号(重新定义类型和其他技巧)。这将使类型/结构非常像Java类。问题是——golang支持这种结构吗?还是我应该坚持到处放星星? 最佳答案 如果您不想到处传递指针,则不必这样做。您可以按值传递结构。例如将您的结构定义为:typeObjectstruct{Xint}然后将您的函数定义为:funcDoStuffToObject(objObje

go - 将指针传递给接口(interface)时函数抛出错误?

这个问题在这里已经有了答案:"ispointertointerface,notinterface"confusion(2个答案)关闭4年前。所以这就是我遇到的,我不明白为什么会出错:packagemainimport("fmt")//defineabasicinterfacetypeIinterface{get_name()string}//defineastructthatimplementsthe"I"interfacetypeFoostruct{Namestring}func(f*Foo)get_name()string{returnf.Name}//definetwoprint

go - 从指针并发读取是否安全?

我正在开发一个图片uploader,并希望同时将图片调整为不同的大小。一旦我将文件作为[]byte读取,我就会将该缓冲区的引用传递给正在同时运行的调整大小函数。这样安全吗?我在想通过传递一个大文件的引用来由调整大小函数读取会节省我的内存,并发会节省我的时间。谢谢! 最佳答案 只读数据通常适合并发访问,但在传递引用(指针、slice、映射等)时必须非常小心。今天,当您还在阅读时,也许没有人在修改它们,但明天可能有人会。如果这是一次性脚本,您会没事的。但如果它是更大程序的一部分,我建议通过明智地保护并发访问来使您的代码面向future。